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(54) Distributed directory services for locating network resources In a very large packet 
switching network 



(57) The present invention relates to a method and 
system of locating a network resource in a packet 
switching network divkled in a bacMaone subnetwork 
connected to one or a plurality of access subnetworks. 
The access subnetworks comprise one or a plurality of 
access border nodes directly connected to the back- 
bone subnetwork. The backbone subnetwork com- 
prises one or a plurality of backbone border nodes 
directly connected to the access subnetworks. Border 
nodes of different subnetworks are connected by border 
links. 

The method in access border nodes involves the 
steps of : 

• receiving a query message comprising a resource 
name, the resource name including a prefix; 

• conrparing the resource name prefix with the pre- 
fixes stored in an access border node directory 
database, said access border node directory data- 
base comprising prefixes of the resources local to 
the access border node subnetwork; 

• determining whether the resource name relates to 
a resource which Is local to the access border node 
subnetwork or not; 

• fonwarding said query message to an adjacent 
backix>ne border node when the resource name 



relates to a resource which is not local to the 
access border node subnetwork. 

The method in backbone laorder nodes involves the 
steps of : 

• receiving a query message comprising a resource 
name, the resource name including a prefix; 

• comparing the resource name prefix with the pre- 
fixes stored in one or a plurality of backbone border 
node directory databases. Each backbone border 
node directory database corresponds to an access 
subnetwork managed the backbone txxder 
node; 

• determining whether the resource name relates to 
a resource which belongs to an access sutxietwork 
that the backbone border node manages or not; 

forwarding the query message to an adjacent 
access t>order node when the resource name 
relates to a resource which belongs to an access 
border node subnetwork managed by the backbone 
border. 

Each access subnetwork has its own spanning tree 
and distributed topology and interactions between 
access networks are limited to a minimum. The size of 
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distributed topologies is kept small and the oontrot traffic 
is mostly limited to subnetworks. 

DIRECTORY SERVICES 
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Description 

Technical field of f/w invention 

[0001 ] The present invention relates to very large a s 
packet switching networks, and more particularly to a ^ 
method and system for creating and n«intaining distrib- 
uted directory services in a network comprising a back- 
bone network connected to one or a plurality of access 
networks. io 

Background art 

HIGH SPEED PACIffiT SWITCHING N ETW O RK S 

15 

[0002] Data transmission is now evolving with a 
specific focus on applications and by integrating a fun- 
damental shift in the customer traffic profile. Driven by 
the growth of workstations, the kx:al area networks 
interconnection, the distributed processing between 20 
workstations and super computers, the new applica- 
tions and the integration of various and often conflicting 
structures * hierarchk;al versus peer to peer, wide ver- 
sus local area networks, voice versus data - the data 
profile has become more bandwidth consuming, burst- 25 
ing. non<leterministic and requires more connectivity. 
Based on the above, there is strong requirement for 
supporting distributed computing applications across 
high speed networks that can carry local area network 
communications, voice, video and traffic among chan- 30 
nel attached hosts, business, engineering workstations, 
terminals, and small to intermediate file servers. This 
vision of a high speed multi-protocol network Is the 
driver for the emergence of fast packet switching net- 
works architectures in which data, vorce. and video 3S 
information is digitally encoded, chopped into small 
packets and transmitted through a common set of 
nodes and tinte. An'effteient transport of mixed traffic 
streams on very high speed lines means for these new 
network architecture a set of requirements in term of 40 
performance and resource consumption which can be 
summarized as follows: 

• a very high throughput and a very short packet 
processing time. 45 

• a very large flexibility to support a wide range of 
connectivity options. 

• an efficient flow and congestion control. 

Throughput and Processing Time so 

[0003] One of the key requirement of high speed 
packet switching networks is to reduce the end to end 
delay in order to satisfy real-time delivery constraints 
and to achieve the necessary high nodal throughput for 55 
the transport of voice and vkJea Increases in link 
speeds have not been matched by proportionate 
increases in the processing speeds of communication 



2 

nodes and the fundamental challenge for high speed 
networks Is to minimize the processing time and to take 
full advantage of the high speed/low error rate technolo- 
gies, most of the transport and control functions pro- 
vided by the new high bandwidth network architectures 
are performed on an end to end basis. The flow control 
and particularly the path selection and bandwidth man- 
agement processes are managed by the access points 
of the network which reduces both the awareness and 
the function of the intermediate nodes. 

Connectivity 

[0004] In high speed networks, the nodes must pro- 
vide a total connectivity. This includes attachment of the 
user's devices, regardless of vendor or protocol . and the 
ability to have the end user communicated with any 
other device. The network must support any type of traf- 
fic including data, voice, video, fax. graphic or image. 
Nodes must be able to take advantage of all common 
carrier facilities and to be adaptatsle to a plurality of pro- 
tocols. All needed conversions must be automatk: and 
transparent to the end user. 

Congestion and Row Controi 

[0005] Communication networks have at their dis- 
posal limited resources to ensure an efficient packets 
transmission. An efficient bandwidth management is 
essential to take full advantage of a high speed network. 
While transmission costs per byte continue to drop year 
after year, transmission costs are likely to continue to 
represent the major expense of operating future tele- 
communication networks as tiie demand for bandwidtti 
increases. Thus considerable efforts have been spent 
on designing flow and congestion control processes, 
bandwidth reservation mechanisms, routing algorithms 
to manage the network bandwidth. An ideal network 
shouki be able to transmit an useful traffic directiy pro- 
portionalto the traffic offered to the network and this as 
far as the maximum transmission capacity is reached. 
Beyond this limit, the network should operate at its max- 
imum capacity whatever the demand is. 

NETWORK CONTROL 

[0006] The flow and congestion control operations 
generate additional traffic on the network. Ideally only 
the exact bandwidth needed at any time by a network 
connection should be dynamically reserved for that con- 
nection, and also only the exact bandwkfth needed for 
tiie network control operations should be resented for 
ttiat purpose. However, it is essential for an efficient flow 
and congestion control to provide at any time enough 
network resources in terms of bandwidth or perform- 
ance to tiie control traffic. The control traffic can be 
divkled Into two main families: 
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• a network signalling control traff ic, and 

• a network routing control traffic. 

Signalling Control Traffic 

[0007] The signalling control traffic is used to estab- 
lish point-to-point and point-to-muttipoint network con- 
nections aaoss the network. Signalling control 
messages are generally forwarded towards the different 
nodes along the path of the connections. The signalling 
control traffic includes: 

• Connection set-up and connection takedown mes- 
sages, 

• Connections bandwidth refresh messages. 

• Connections bandwkfth adaptatk)n 
(inaease/decrease) messages, 

• Directory queries in network (directed to a specific 
resource), ... 

Routing Control Traff k: 

[0008] The routing control traffic is used for distrib- 
uting the network topology information between nodes 
of the network. This information is necessary mainly for 
the computation of routing paths between nodes In the 
network. Routing control messages are generally 
broadcasted to all nodes by means of Spanning Tree or 
flooding mechanisms. The routing control traffic 
includes: 

• Control Point Spanning Tree maintenance mes- 



• Topology update messages 

• Directory searches in network (broadcast through 
the network), ... 

LARGE NETWORKS 



the use of carrier links between nodes. The bacMx)ne 
network is generally a public network but can also be 
part of a private network using lines leased from a car- 
rier such as the PTT. 

5 

bandwidth Reservation for Control Traffic 

[0011] Because of the high importance of network 
traffic, enough bandwidth on the links must be reserved 

10 to transmit the routing and signalling control messages. 
Insufficient resources for routing control messages 
could lead to invalid topology tables and a node, with an 
erroneous or obsolete view of the network topology, 
may take wrong routing decisions. Insufficient 

15 resources for the signalling control messages could 
also lead to enors or at least to a degradation of the 
quality of service in the establishment and management 
of network connections. US patent application no 
771333 (EP patent application no 95480178.3. IBIS'S 

20 reference FR9 95 017) entitled "Dynamic Bandwidth 
Reservation for Control Traffic in High Speed Packet 
Switching Networks" discloses a method and system for 
reserving dynamically and in priority for each link of the 
network the exact amount of bandwidth necessary for 

2S the transmission of the network control traffic. An evalu- 
ation of the expected control traffic on each link of the 
network is performed in order to allocate a sufficient but 
minimum fraction of the link bandwidth and for allocating 
tiie maximum available bandwidth for the user traff la 

30 

Hierarchical Networks 

[0012] Hierarchical networks have been proposed 
for a while, and such architectures are cunrentiy devel- 
35 oped for example with PNNI (Private Network to Net- 
work Interface) for ATM (Asynchronous Transfer Mode) 
networks or NBBS (Networking BroadBand Services) 
for IBM (Intemational Business Machine) networks. 



[0009] As shown in Rgure 6, large networks suffer 
from tine large amount of control traffic necessary to 
update tiie distributed network topologies in view of the 
high number of nodes and transmission links. Directory 
queries are also an Important contrikxjtor to the control 
traffic load The problem is particulariy sensible on 
spanning tree links and on links issued from access 
nodes. For optimizing the resources, in particular the 
bandwidth where it is the more demanded, several solu- 
tions have been considered. 
[0010] Most of tiie wide networks (large country, 
world-wide networks) are configured so that a backtx)ne 
network can support the communications between dif- 
ferent access networks. Such network topology allows 
good performances and tiie optimisation of the network 
administration. Generally, access networks are private 
networks and indeed they are very often confined to a 
local area such as a building or a campus. However, a 
private network can be distributed over a wide area by 



Private Network to Network Interface 

[0013] The Private Network to Network Interface 
(PNNI) is described in in tiie ATM Forum specifications 
(PNN1 1.0 Specs March 1996), however a summary can 
be found in publication entitled "Asynchronous Transfer 
Mode Networks - Performance Issues", second edition 
Artech House 1995 (Raif O. Onvural) incorporated 
herewith by reference, PNNI is the demarcation point 
between two switching systems. In this context, a 
switching system may be : 

• a single ATM switch. A PNNI is used between every 
pair of neighbour switches in the network. These 
switches may be built by different vendors. ATM end 
stations are attached to the network across UNls 
(User to Network Interface). 

• altematively, a collection of two or more ATM 
switches managed and operated under one admin- 
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istration. The network may be built with switches 
from a single vendor. This would eliminate the dis- 
advantages of operating at the level provided by the 
PNNI and allow it to take advantage of vendor spe- 
cific network services and solutions toward utilizing 
network resources efftoiently. 

[0014] In the former case, the PNNI becomes a 
switch to switch interface, whereas in the later case, it is 
referred to as an network to network interface (NNi). 
PNNI includes the definitions of varbus physical inter- 
faces. ATM layer, management interface, and signalling. 
The ATM Forum PNNI specifications Includes both rout- 
ing and signalling functions: 

• PNNI routing comprises various "generic* network 
control functions, such as call admission, path 
selectton. and topology distribution. 

• PNNI signalling is used to can-y PNNI routing 
related protocol information as well as perform call 
control functions for connection establishment, 
management and termination. 

[0015] In PNNI routing, the switching system that a 
connection request originates from its UNI is responsi- 
ble for finding the end to end path to the destination end 
station. This is referred to as "source routing". For each 
connection request, the source switching finds a path 
based on the advertised capabilities and the desirability 
of other switching systems to carry connections with dif- 
ferent characteristics. After finding the path, the origi- 
nating switching system uses PNNI signalling to request 
connection establishment from Intermediate switching 
systems along the path. PNNI routing is based on link 
state routing. Each switching system advertises a set of 
parameters including information about the links 
attached to it, quality of service parameters it can guar- 
antee, and its capability and desirability to carry particu- 
lar types of connections. Assuming that each switching 
system sends a message advertising the status of 
resources it controls as soon as a change takes place 
(i.e.. upon accepting or terminating a connection). This 
message will an-ive at other switching systems (at the 
minimum) after the conresponding propagation delays. 
Accordingly, source switching can never have up to date 
information about the status of other switching systems. 
Inaeasing the frequency and the amount of information 
advertised may be thought to enable "better" paths to 
be chosen. Doing so wouM also result in significant cost 
in bandwidth and processing complexity. At the other 
extreme. If no information is advertised then the 
chances of choosing "poor paths wouM increase. The 
topology update mechanism in ATM networks needs to 
be designed with care. Otherwise, the cost of bandwidth 
and the processing complexity may not be justified 
when compared with the amount of network efficiency 
achieved. 

The choice of what internal state Information to adver- 
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tise, how often, and to where require the specif ication of 
a multilevel Nerarchical routing nmiel. The PNNI hierar- 
chical model is recursive and at each level of hierarchy, 
the topology is represented by bgicaJ nodes and logical 

5 links. At the lowest level of hierarchy, each node repre- 

^ sents a real switching system or a group of swftching 
system. At higher layers, each node may represent 
either a real system or a group of switching systems. 
Similarly. PNNI links may con^espond to either a real 

10 physical link or a virtual link. 

Nodes are collected into peer groups. All the nodes 
within a peer group exchange link information and 
obtain an kientical topology database representing the 
peer group. Peers groups are organized into a hierarchy 

75 in which one or nfx)re peer groups are associated with a 
parent peer group. Parent peer groups are grouped into 
higher layer peer groups. 

The operation of PNNI routing In a parent group 
attempts to collapse a child peer group into a single 

20 node. In this case, there wouM be different paths to 
cross a peer group, each with different characteristics. 
Hence. It is not always possible to advertise the true 
cost of the real physical paths. The representatton of 
peer groups and their interconnections as k>gical nodes 

25 and logical links implies that infbnnation distnbuted at 
higher layers is summarized. This allows the routing to 
scale to very large networks. Its consequence is that 
somewhat inperfect paths may be selected. 
[0016] To summarize, the PNNI routing uses the 

30 concept of abstraction. Nodes and links not pertaining 
to the local peer group do not appear as such but are 
factored in a topology summary. The summarized topol- 
ogy is built of a much smaller number of nodes and 
links. While the amount of control traffic is proportional 

3S to the topology size, the corresponding control traffic for 
distributing the topology is reduced accordingly. The 
drawback is tiie complexity and imperfection introduced 
by the hierarchy. 



[0017] The NBBS (Networking BroadBand Serv- 
ices) spanning tree function supports the routing control 
traffk: by interconnecting once every node in the net- 

45 work by means of a logical tree. Each node on the span- 
ning tree maintains a parent-child relationship with Its 
adjacent node. At any one time, one of the nodes Is ttie 
root of tiie spanning tree and this node coordinates ttie 
construction and maintenance of the tree. When the 

50 topology of ttie network changes because a node or link 
Is activated or deactivated, a new root will be dynami- 
cally selected. Assuming an edge is a link that is part of 
tine spanning tree, although every node in tine network is 
in the spanning tree, only ttie minimum number of 

55 edges is used in ader to connect the nodes. The main 
reason for using a spanning tree is that it allows infor- 
mation that has to go to every node to be sent very 
quickly and efficientty. Every node receives a single 
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oopy of every message (compared to many copies in 
the case of broack:ast technology). However the span- 
ning tree maintenance cannot cope easily very targe 
network (several hundreds of nodes) or unstable net- 
works which request frequent rearrangements or recon- 
nections. 

[0018] More details concerning NBBS and more 
particularly the NBBS spanning tree can be found in the 
following publications : 

• "Networking BroadBand Services (NBBS). Archi- 
tecture Tutoriar. IBM International Technk»l Sup- 
port Centers GG24-4486-00 June 1995. 

• "Communication-Optimal Maintenance of Dynamic 
Trees" by Bamch Awerbuch et al, 1/25/90 research 
report. 

• "Multicast Group Memt}ership Management in High 
Speed Wide Area Networks" Auerbach et al, Inter- 
national Conference on Distributed Computing Sys- 
tems, Arlington , Texas, May 20-24. 1991. Institute 
of Etectrk^ and Electronics Engineers, pages 231 
-238. 

• IBM Technical Disclosure Bulletin 'Distributed Tree 
Maintenance" by et Cidon al. Vol. 35 No. 1 A. pages 
93-98. June 1992. RA891044. 

• European patent application 93480060.8 entitled 
"Multicast Communication Tree Creation and Con- 
trol Method and Apparatus" Auert>ach et al (prtority 
date 18/06/92). 

Decorrpositbn of Network Topology 

[0019] In the real world . large transport networks 
are not fully meshed. Networks are usually built around 
a hierarchical structure. A set of nodes interconnected 
by high throughput links are used to buikl a l>ackbone" 
with a high degree of meshing to allow the redundancy 
and reliability required by the user. Then local nodes are 
grouped in geographical "subnetworks" themselves 
attached to the backbone. The control traffic can take 
advantage of the particular network topology to drasti- 
cally reduce the network load. For a given connection, 
only a limited number of nodes are defined as eligible 
and are taken in account by the routing algorithm in the 
optimal route search. 

[0020] US patent 5.495.479 (EP application 
number 93480105.1 , IBM's reference FR 9 93 013 enti- 
tled "Method and Apparatus for an Automatic Decompo- 
sition of a Network Topok)gy into a Backbone and 
Subareas" (C. Galand et al.) discloses a method and 
system for performing an automatic decomposition of a 
network into a backbone and subareas to speed up the 
path selection process without degrading the optimiza- 
tion criterion of the routing algorithm and without gener- 
ating additional control messages on the network. The 
selection of a routing path in an access node involves 
the steps of storing the network configuration; automat- 
ically pre-selecting a set of usable links for each desti- 
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nation node located in the network; storing k)ca!ly said 
pre-selection of usable links: determining, for each con- 
nectk>n request between said access node and a desti- 
nation node, a routing path among sakJ pre-selected 
5 usable links. 

Objects of the Invention 

[0021] The object of the present invention is to 
10 locate a network resource in a very large network 
divkied in multiple subnetworks. 
[0022] It is a further object to limit in large networks 
the control traffic and in particular, topology update 
messages, control point spanning tree maintenance 
75 messages ... 

it is another object not to overload the network with mul- 
tiple directory queries. 

[0023] It is a another object to linrut the size of the 
network topology that a node can access to the subnet- 
20 work it belongs to. 

[0024] It is another object to define a simple and 
effective method and system for locating a resource in 
large networks. 

25 Summary Of the Invention 

[0025] The present invention relates to a method 
and system of locating a network resource in a packet 
switching network divided in a backbone subnetwork 

30 connected to one or a plurality of access subnetwork. 
The access subnetworks comprise one or a plurality of 
access border nodes directiy connected to the back- 
bone subnetwork. TTie backbone subnetwork com- 
prises one or a plurality of backbone border nodes 

35 directly connected to the access subnetworks. Border 
nodes of different subnetworks are connected by border 
links. 

[0026] The method in access border nodes involves 
the steps of: 

40 

• receiving a query message comprising a resource 
name, the resource name including a prefix: 

• comparing the resource name prefix with the pre- 
45 fixes stored in an access border node directory 

database, said access border node cfirectory data- 
base comprising prefixes of the resources local to 
the access border node subnetwork; 

50 • determining whether the resource name relates to 
a resource which is local to tiie access t>order node 
subnetwork or not; 

• foHA/arding said query message to an adjacent 
55 backbone border node when the resource name 

relates to a resource which is not local to the 
access border node subnetwork. 
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[0027] The method in backbone border nodes 
involves the steps of: 

receiving a query message comprising a resource 
name, the resource name including a prefix; 

• comparing the resource name prefix with the pre- 
fixes stored in one or a plurality of backbone border 
node directory databases. Each backbone border 
node directory datdk>as6 corresponds to an access 
subnetwork managed by the backbone border 
node; 
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ing to the present invention. . 

Rgure 7 shows the Directory Services Proxies 
according to the present invention. 

Figure 8 is a flow chart of the broadcasting mecha- 
nism according to the present invention. 

Figure 9 is a flow chart of the procedure called 
when the Directory Services Proxy located in the 
access network receives a request message 
according to the present invention. 



• determining whether the resource name relates to 
a resource which belongs to an access subnetwork 
that the backbone border node manages or not; 

• forwarding the query message to an adjacent 
access border node when the resource name 
relates to a resource which belongs to an access 
border node subnetwork managed by the backbone 
border. 

[0028] Each access subnetwork has its own span- 
ning tree and distributed topology, and interactions 
between access networks are limited to a minimum. 
The size of distributed topologies is kept small and the 
control traffic is mostly limited to sub networks. 

Drawings 

[0029] The novel and inventive features believed 
characteristics of the invention are set forth In the 
appended claims. The invention itself, however, as well 
as a preferred mode of use, further objects and advan- 
tages thereof will best be understood by reference to the 
following detailed description of an illustrative detailed 
embodiment when read in conjunction with the accom- 
panying drawings, wherein: 

• Figure 1 shows the bandwidth used by the control 
traffic in function of the number of nodes within the 
network. 

• Figure 2 shows a typical speed packet switching 
network. 

• Figure 3 desaibes a high speed routing point 

• Figure 4 shows two users establishing a communi- 
cation over a packet switching network. 

Figure 5 desaibes the Topology DataBase struc- 
ture. 

Figure 6 shows the distribution of the topology in a 
network comprising a backbone subnetwork con- 
nected to a plurality of access subnetworks accord- 



Figure 10 is a flow chart of the procedure called 
15 when tiie Directory Services Proxy in the backtxxie 
network receives a request message according to 
tiie present invention. 

Rgure 11 is a flow chart of process for initializing 
20 tiie link bridge and tiie associated Directory Serv- 
ices Proxies according to the present invention. 

Preferred embodirnent of ttte invention 

25 I PRIOR ART 

HIGH SPEEP CQMMUNICATIQNS 

[0030] As illustrated in Figure 2, a typical model of 

30 oommunk^tion system is made of several user net- 
works (212) communicating through a high perform- 
ance network (200) using private lines, earner provided 
services, or public data networks. Each user network 
can be desaibed as a set of communication processors 

35 and links (211) interconnecting large computers used 
as enterprise servers (213), user groups using worksta- 
tions or personal computers attached on LAN (Local 
Area Networks 214), applications servers (215), PBX 
(Private Branch exchange 216) or video servers (217). 

40 These user networks, spread in different establish- 
ments, need to be interconnected tiirough wide area 
ta'ansport facilities and different approaches can t>e 
used for organizing the data transfer. Some architec- 
tures involve the checking for data integrity at each net- 

45 work node, thus slowing down the transmission. Otiiers 
are essentially looking for a high speed data transfer. To 
that end tiie transmission, routing and switching tech- 
niques within tiie nodes are optimized to process tiie 
f fowing packets toward their final destination at tiie high- 

so est possible rate. The present invention belongs essen- 
tially to the latter category and more particularly to ttie 
fast packet switching network architecture detailed In 
tiie following paragraphs. 

55 High Performance Packet Switching Networks 

[0031] The general view in Figure 2 shows a fast 
packet switching transmission system comprising eight 
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nodes (201 to 208) each node being interconnected by 
means of high speed communication lines called Trunks 
(209). The access (210) to the high speed network by 
the users is realized through Access Nodes (202 to 205) 
located at the periphery. These Access Nodes comprise 5 
one or more Pats, each one providing an access point 
for attaching external deuces supporting standard inter- 
faces to the network and performing the conversions 
required to transport the users data flow across the net- 
work from and to other external devices. As example. 10 
the Access Node (202) interfaces respectively a Private 
Branch exchange (PBX). an application server and a 
hub through three Ports and communicates through the 
network by means of the adjacent Transit Nodes (201), 
(205) and (208). 75 

Switching Nodes 

[0032] Each network node (201 to 208) includes a 
Routing Point where the incoming data packets are 20 
selectively routed on the outgoing Trunks towards the 
neighbouring Transit Nodes. Such routing decisions are 
made according to the information contained in the 
header of the data packets. In addition to the basic 
packet routing function, the network nodes provkle ss 
ancillary services such as: 

• the determination of routing paths for packets origi- 
nated In the node. 

• directory sen/ices like retrieving and updating infer- 30 
mation about network users and resources. 

• the maintaining of a consistent view of the physical 
network topology, including link utilization informa- 
tion, and 

• the reservation of resources at access points of the 3S 
network. 

[0033] These ancillary sennces include: 

• the storage within the node of ahemate paths. 40 

• the ipdating of these paths. 

[0034] Each Port is connected to a plurality of user 
processing equipment, each user equipment compris- 
ing either a source of digital data to be transmitted to 45 
another user system, or a data sink for consuming dig- 
ital data received from another user system, or. typically, 
both. The interpretation of the users protocols, the 
translation of the users data into packets formatted 
appropriately for their transmission on the packet net- so 
work (200) and the generation of a header to route 
these packets are executed by an Access Agent running 
in the Port This header is made of Control. Routing and 
Redundancy Check Fields. 

55 

• The Routing Fields contain all the information nec- 
essary to route the packet through the network 
(200) to the destinatfon node to which it is 



addressed. These fields can take several formats 
depending on the routing nxxie specified (connec- 
tion oriented or oonnectfonless routing mode...). 

• The Control ReWs include, among other things, an 
encoded identification of the protocol to be used for 
interpreting the Routing Relds. 

• The Redundancy Check Rekis are used to check 
for enrors in the header itself. K an error is detected, 
the packet Is discarded. 

Routing Points 

[0035] Rgure 3 shows a general block diagram of a 
typical Routing Pdnt (300) such as it can be found in the 
network nodes (201 to 208) illustrated in Figure 2. A 
Routing Point comprises a high speed packet Switch 
(302) onto which packets arriving at the Routing Point 
are entered. Such packets are received: 

• from other nodes over high speed transmission 
links (303) via Trunk Adapters (304). 

• from users via application adapters called Ports 
(301). 

[0036] Using information in the packet header, the 
adapters (304. 301) determine which packets are to be 
routed by means of the Switch (302) towards a local 
user network (307) a towards a transmission link (303) 
leaving the node. The adapters (301 and 304) include 
queuing circuits for queuing packets prior to or subse- 
quent to their launch on the Switch (302). 
[0037] The Route Controller (305) calculates the 
optimum paths through the network (200) so as to sat- 
isfy a given set of quality-of-services specified by tiie 
user and to minimize the amount of network resources 
used to complete the communication path. Then, It 
builds the header of the packets generated in the Rout- 
ing Point. The optimization criterion includes the 
number of intermediates nodes, the characteristics of 
the connection request, the capabilities and the utilisa- 
tion of the lihks (Trunks) in the path, the number of Inter- 
mediate nodes... The optimum route is stored in a 
Routing Datafc>ase (308) for further reuse. 
[0038] All the information necessary for the routing, 
about the nodes and transmission links connected to 
the nodes, are contained in a Netwak Topology Data- 
base (306). Under steady state condition, every Routing 
Point has the same view of tfie network. The network 
topology information is updated when new links are acti- 
vated, new nodes added to the network, when links or 
nodes are dropped or when link loads change signifi- 
cantly. Such information is exchanged means of con- 
trol messages with all other Route Controllers to provtie 
the up-to-date topological information needed tor path 
selection (such database updates are carried on pack- 
ets very similar to the data packets exchanged between 
end users of the network). The fact tiiat the network 
topology Is kept current in every node tiirough continu- 
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ous updates allows dynamic network reoonfigurations 
without disrupting end users logical connections (ses- 
sions). 

[0039] The incoming transmission links to the 
packet Routing Point may comprise links from external s 
devices in the local user networks (21 0) or links (Trunis) - 
from adjacent network nodes (209). In any case, the 
Routing Point operates in the same manner to receive 
each data packet and forward it on to another Routing 
Point is dictated by the information in the packet header. io 
The fast packet switching network operates to enable a 
communicatbn between any two end user applicatk)ns 
without dedicating any transntission or node faculties to 
that communication path except for the duration of a sin- 
gle packet In this way, the utilisation of the communica- is 
tion facilities of the packet network is optimized to carry 
signrficantly more traffic than would be possible with 
dedk^ated transmission links for each communication 
path. 

20 

NETWORK MANAGEMENT 
Network Control Functions 

[0040] The Network Control Functions are those 25 
that control, allocate, and manage the resources of the 
physical network. Each Routing Point has a set of the 
foregoing functions in the Route Controller (305) and 
uses it to facilKate the establishment and the mainte- 
nance of the connections between users applications. 30 
The Network Control Functions include in particular: 

• Directory Services 

• for retrieving and maintaining information about 35 
network users and resources. 

• Bandwidth Management 

• for processing the bandwidth reservation and 40 
maintenance messages, and 

• for monitoring the current reservation levels on 
links. 

• Path Selection 45 

• for choosing the best path for each new con- 
nection considering the connection require- 
ments and the current link utilisation levels. 

so 

• Control Spanning Tree 
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link/node lailures. 

• Topology Update 

• for distributing and maintaining, using the 
Spanning Tree, information about the logical 
and physical network (including link utilization 
Information) in every node. 

• Congestion Control 

• for enforcing the bandwkjth reservation agree- 
ments t)etween the network's users and the 
network which are established at the call set up 
time, and 

• for estimating actual bandwidth and for adjust- 
ing reservation if necessary during the life of 
the connection. 

TOPOLOGY DATABASE fTDB) 

[0041] The Topology Database contains informa- 
tion atx)ut nodes, links, their properties, and the band- 
width allocation. The topology information is replicated 
in each node of the network. An algorithm guarantees 
the correctness of each node's Topology Database 
when links and nodes are added or deleted or when 
their characteristics change. The database comprises: 

• the physical topology of the network whtoh Includes 
static information like physical characteristics of 
nodes and links, 

• the state of nodes and links, and 

• tiie link utilisation which includes dynamic charac- 
teristics like current bandwklth (used and 
reserved), real-time measurements... 

[0042] The general organisation of the Topology 
Database is shown in Figure 5. To each resource in the 
network, nodes (501) or links (502). is associated an 
entry in the database. In particular, each link entry 
includes the following characteristics: 

• (503) the link physical properties : 

• transmission medium and speed, 
routing mode supported, 
maximum packet size. 

link buffer capacity. 

• propagation delay. 

• bandwidth reservation supported... 



• for estat)lishing and maintaining a routing tree 
among the network nodes. 

for using K to distribute control information (in ss 
parallel) including link utilisation, and 

• for updating the Topology Database of the 
nodes with new network configuratfons or 



(504) the link state: 

• on-line (link can accept user connections), 

• quiescent (link cannot accept additional user 

• connections, but existing connections con- 
tinue), 
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• off-line (link cannot accept user connections 
and existing connections are cancelled)... 

• (505) the link utilization: 

real-time measurements. 

• reserved bandwidth,... 

[0043] The Topology maintenance consists of 
advertizing and gathering the updates that occur inside 
the netwalc Changes can be of three types : 

• The first type deals with \mk physical properties : 
additional linK link removal, reconfiguration ... 

• The second type deals with link state. 

• The third type deals with dynamic link utization. 

[0044] The concept of distributed topology 
assumes that each Control Point has the same view of 
the network. 

DIRECTORY SERVICES 

[0045] The Directory Services are responsikjle for 
locating users in the network. Users are connected to 
external networks, which attach into the network via 
access agents located in access nodes. The Directory 
Services function is distributed around all the drectory 
agents which reside in access agents. They are used on 
behalf of users when network connections are being 
established. 

Users of the Network 

[0046] A user Is kJentif ied uniquely tsy its "resource 
name", which desaibes the user in its native protocol. 
The access agent in the access node communicates 
with users using their native protocols and names, but 
uses the particular network protocols and names when 
communicating with other network nodes. Directory 
Services is responsible for the mapping of a resource 
name into a particular network name. The user's 
resource name is specified using the following three 
value : 

• Resource Identifier Type : this describes the 
addressing scheme used for this user (E.164, 
X.121, NSAP. ...). 

Resource Identifier : this identifies a user within the 
syntax of the network described by the resource 
identifier type. 

Resource Identifier Prefix : The prefix is used to 
group together users of the same resource identi- 
fier type. The prefix is optional and used when 
directory services implements directory sets. 
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Directory Database 

[0047] Directory services uses a distributed direc- 
tory database. Each directory agent maintains its own 

5 local directory database which contains information 
.about users of the network. A local directory database 
has records for a subset of all the users of the network. 
Combining all the local directory databases from the 
directory agents would give a complete view of the dis- 

10 tributed directory database. This is different from the 
Topology Services with its fully replicated Topology 
Datat)ase that gives every node a complete view of the 
network's topotogy. A local directory database agent is 
managed by each directory agent. A node will have mul- 

IS tiple local directory database if there are multiple 
access agent on the node. From a view point of direc- 
tory services on a node, there are two sorts of users: 

Local user : local users are those which gain 
20 access to the network through this directory agent. 

• Remote users : remote users are those which gain 
access to the network through a different directory 
agent. 

25 [0048] The directory datak)ase contains a number 
of directory entries. An entry is present for each local 
user. There are also entries for some of the remote 
users. The infamation which is kept in a directory entry 
includes among other parameters : 

30 

• resource identifier and prefix; 

• resource identifier type; 

• network addresses of the resource's access agent 
conponents (directory agent, protocol agent, con- 

35 nection agent); 

• etc .. 

[0049] Figure 4 shows two users who are establish- 
ing a communication in a network. It is assumed that 

40 User 1 (who is connected to node X), is setting up com- 
municatbn with User 2 (connected to node Y). Directory 
servtees on node X happens to have a cache entry for 
User 2 as a result of a previous query. However, just 
knowing the external name (the resource name) is not 

45 enough to calculate a path across the network. The 
information about the access agent addresses is 
required because this is how a remote user is located 
and his network connection estat)lished. 
[0050] Information in the local directory database 

so can come from different sources : 

• Home entry : entries for local or renrK3te users are 
generated in the local node using configuration 
information provided by the customer. 

55 • Registered entry : information about local users 
can be provided using signalling as a result of an 
external search. 

• Cached entry : remote users are k)cated as a result 
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of distributed queries (searches), and the infbrma- subnetwork to another afthough this is not a restric- 

tion cached. lion. 



Distributed Queries 

5 

[0051 ] Directory services always inspects the local ^ 
directory database for a target user. 

• If the target user is a local user, then a distributed 
query is not required. io 
If a directory agent needs to inspect another part of 
the distributed directory database, a distributed 
query is used in order to locate a target user. 

[(M)52] The distributed queries are so called is 
because it is a search which is distributed anwng a 
group of remote directory agents. Distributed queries 
are sent from an origin directory agent to one or more 
destination directory agents, using either a directory set 
(a directory set Is a group of directory agents which sup- 2o 
port users with the same longest matching address pre- 
fix) or the spanning tree. 

Undirected Explicit Queries 

2S 

[0053] This type of query is used if the local direc- 
tory datak>ase doe not contain any information about the 
user to be located. The origin directory agent multicasts 
the query to the appropriate directory group using a 
defeult distribution tree (a default distribution tree is a oo 
tree which spans ail the members of a particular direc- 
tory set). A remote directory agent will only reply to this 
type of query if it provides access to the destination 
user. A positive reply means that the destination user is 
a local member of the directory database of the destina- 35 
tlon directory agent. When a directory agent replies 
positively to a query, it will provide the location of the tar- 
get user, in terms of the addresses of its access agent 
components. 

40 

II PRESENT INVENTION 
NETWORK STRUCTURE 

[0054] The network according to the present inven- 45 
tion, is partitioned into two types of subnetworks. The 
topology distribution is effective at the subnetwork level 
only. 

Access subnetworks have a limited number of so 
nodes and links. These nodes are basically used 
for accessing the network as source nodes or des- 
tination nodes. 

• The backbone subnetwork is unique and generally 55 
comprises a higher number of nodes and links than 
access subnetworks. The backbone subnetwork is 
mostly used for transmitting traffic from an access 



[0055] Consequently, nodes are not functionally 
specialized even If they belong to different types of sub- 
network. Access subnetworks may have direct links in 
between but an access subnetwork should not be used 
for transmitting traffk; from an access node to another. 
An access subnetworic and the backbone subnetwork 
may be connected by several links. 

• A node that belongs to an access subnetwork and 
that Is directly connected to the backbone subnet- 
vtork is called "access border node**. 

• A node that belongs to the backtxxie suk>network 
and that is directly connected to an access subnet- 
work is called "backbone border node". 

• A link i>etween tx)rder nodes of different subnet- 
wortcs Is called "tx>rder link*. 

[0056] Figure 6 shows a typical network comprising 
a backbone subnetwork interconnected to a plurality of 
access subnetworks (access subnetworks 1. 2, 3) : 

Nodes A. B, C .. M are interconnected with trans- 
mission links. 

• The backbone subnetwork comprises nodes D, E. 
F.G. 

• Access subnetwork 1 is built of nodes A. B. C. 
Access subnetwork 2 Is built of nodes I. J, H. 
Access subnetwork 3 is built of nodes K. U 

• Nodes B. C, K, L, H, I are access border nodes. 
Nodes D. E. F. G are backbone border nodes. 

• Unks C-E. B-D. K-D. L-G. I-G, H-F. L-l are border 
links. 

[0057] A node is Identified by means of a subnet- 
work identifier and a node identifier, this node identifier 
is unique within the subnetwork the node belongs to. A 
specific identifier is used to identify the backbone sub- 
network. In each subnetwork (access or backbone) the 
associated topology content is shown In a TDB pattern. 

TOPOLOGY DATABASE fTDB) 

[0058] Each node within a same subnetwork has 
the same view of the subnetwork topology. The infbrma- 
tion contained in the Topology DataBase (TDB) Is lim- 
ited to the subnetwork level and to adjacent border 
nodes : there is no systematic replication between sub- 
networks. As described previously, entries in the Topol- 
ogy DataBase are of two types : node or link. There is 
one node entry for each subnetwork node (nodes A. B. 
C) and each adjacent border node (nodes E. D). There 
is one link entry for each unidirectional link. Each unidi- 
rectional link being attached to its origin node, the sub- 
network Topology DataBase (TDB) contains all the 
unidirectional links attached to the subnetwork nodes. 



35 
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This includes the unidirectional bader links of the sut>- 
network border nodes (C ->E, B->D). 
As shown in Rgure 6. the different Topology DataBases 
(TOB) are exclusive. However, they partially share each 
other the Knowledge of the t>acktx)ne subnetwork a the 
knowledge of the adjacent access subnetworks (adja- 
cent border nodes and border links). For Instance, the 
Topology DataBase of access subnetwork 1 comprises 
all the nodes (A, B. C) located within this subnetwork, 
the corresponding outgoing unidirectional links (A -> B. 
A -> C. B -> A, B •> C. B -> D. C •>A. C -> B. C -> E) and 
the backbone border nodes (D, E). Unidirectional border 
links (B -> D. C -> E) of access border nodes (B. C) are 
included. 

[0059] In the present invention, local subnetwork 
Topology DataBases are neither duplicated nor con- 
catenated. They are used bcally : 

• fbr implementing: 

in each access subnetwork, an access subnet- 
work Directory Services Proxy in an access 
border node and 
• in the backbone subnetworK a backbone sub- 
network Directory Services Proxy in backbone 
border nodes. 

• fbr defining a unique link brkjge fbr each access 
subnetwork. 

DIRECTORY SERVICES 

[0060] The locating of network resources is neces- 
sary in order to set up a network connection between a 
source and a destination. As detailed previously, a 
resource is uniquely identified by a resource name 
which usually follows an addressing scheme, E164. 
NSAP for example. It is assumed that the addressing 
scheme is structured so that, in most case, a prefix can 
be extracted and the relation to a given subnetwork be 
assigned. In small networks, the resource search can 
be simply an undirected query message broadcasted to 
every node. On the contrary, in large network it is not 
possible to broadcast every query message without 
overloading the network. The netwak partitioning into 
access sutxietworks and backbone subnetwork gives 
the opportunity to improve the efficiency of the broad- 
casting mechanism while remaining unchanged the 
existing search mechanism in nodes. 

Link Bridge 

[0061] Several links may interconnect an access 
subnetwork and the backt>one subnetwork. In order to 
avoid duplication of undirected searches outside the 
originating subnetwork, a unique link is selected to 
become a "link bodge** between two border nodes of dif- 
ferent types: access subnetwork border node and back- 
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bone subnetwork border node. There is a sin^e link 
bridge per access subnetwork. 

Directory Services Proxies 

5 

.[0062] In tx>rder nodes (access border node and 
backbone border node) of each subnetwork bridge link, 
a Directory Services Proxy is implemented : 

10 • The purpose of an access subnetwork Directory 
Services Proxy is to determine whether an undi- 
rected query message relates to a resource that is 
local to the subnetwori^ or a resource that belongs 
to another subnetwork. The undirected qu^'y mes- 

IS sage is either discarded or fbnA^arded accordingly 

• The purpose of a backbone subnetwork Directory 
Services Proxy is to determine whether a query 
message relates to a resource that belongs to a 

20 subnetwork it manages or not. 

[0063] Figures 7 and 8 are showing an undirected 
query issued from an access subnetwork 

25 Broadcasting Mechanism 

[0064] 

• 801 : Source node A - A query message with a 
30 resource name (or address) is sent by the Directory 

Services of source node A preferably using the 
services of the source subnetwork spanning tree. 

• 802 : Border node B - This query message is inter- 
as cepted and read by the Directory Sen^ices Proxy 

located in access border node B. TWs Directory 
Services Proxy determines whether this query 
message relates to a local resource or not. Query 
message with a non local resource name (resource 

40 name - "0492115952" fbr instance - that doesn't 
match any access subnetwork 1 resource identifier 
prefix in the directory database of node B) are for- 
warded to the backbone subnetwork. Query mes- 
sages with a local resource name are forwarded 

45 along the subnetwork spanning tree. 

Note : in a preferred embodiment, query mes- 
sages are forwarded to the t>ackbone subnetwork in 
Remote Access to Label-Swap Tree transfer mode 
which is a combination of the ANR (Automatic Net- 

50 work Routing) and label swapping transfer oKx^es. 
The remote access to label-swap tree transfer 
mode uses ANR to transfer a packet for the first part 
of its journey and then uses label swapping for the 
remainder of the journey The remote access to 

55 Label-Swap tree is used because packets may be 
repficated at some transit nodes and each repli- 
cated packet sent to a different destination with a 
different label. 
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• 803 : BacMsone tx>rder node D - Node D has its 
own directory database but has also access to the 
directory database of the access subnetwork Direc- 
tory Services Proxies of the access subnetworks it 
manages. At reception of the query message, node s 
D determines whether it is targeted to an access ^ 
subnetwork it manages (access subnetwork 3) or 
not Because In our example, node D does not rec- 
ognize in the query message a resource identifier 
prefix that corresponds to the access subnetwork It ro 
manages, It forwards the query message to the next 
node (node G) on the backbone subnetwork span- 
ning tree. Node G forward in Its turn the query mes- 
sage to node R 

15 

• 804 : Node F - Node F recognizes that the resource 
name corresponds to an access subnetwork that It 
manages (the address *049211-i-" matches the 
resource identifier prefix of access subnetwork 2). It 
forwards the query message to this access subnet- 20 
work via the link bridge (F->H). 

• 805 : Node H - The access border node H multi- 
casts on the subnetwork spanning tree the query 
message within the access subnetwork 2. 25 

• 806 : Node J - Node J receives the muitlcasted 
query message as any node in the access subnet- 
work 2, recognizes the ownership of the resource 
and prepares a response. TMs response Is sent 30 
directly to the requester (node A) thanks to the 
Reverse Path Accumulation function. 
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of the proxy directory .database (a resource 
klentifier prefix), the procedure goes on with 
step (903) 

• 902 : the resource name of the target has been 
found, therefore the request Is forwarded to the next 
node on the access subnetwork spanning tree and 
the procedure terminates on step (904). 

• 903 : the resource name of the target has not been 
found, therefore the request Is forwarded on the link 
brkige to the Directory Servtees Proxy located in 
the border node of the bacMx>ne subnetwork. Die 
procedure terminates on step 904. 

Proxy in Backbone Subnetwork 

[0067] Rgure 1 0 shows the procedure that is called 
when a Directory Services Proxy in a backkx)ne subnet- 
work receives a query message : 

• 1000 : the procedure is triggered at reception of a 
request message. 

1001 : a test determines whether or not the 
resource name of the target resource matches a 
proxy directory database entry (resource identifier 
prefix stored in the directory database of the back- 
bone border node). 

• If the resource name matches an entry In the 
proxy directory datat>ase (resource identifier 
prefix), the procedure goes on with step (1003) 



[0065] Note : The Reverse Path Accumulation func- 
tion enables the path that a packet has traversed 
through the network to be recorded in the header of the 
packet This can then be used by the recipient of the 
packet to efficiently construct a reply packet 

Proxy in Access Subnetworks 

[0066] Figure 9 shows the procedure that is called 
when a Directory Services Proxy in an access subnet- 
work receives a query message : 

• 900 : the procedure is triggered at reception of a 
request message. 



• If the resource name does not match any entry 
35 in the proxy directory datak>ase (a resource 

identifier prefix), the procedure goes on with 
step (1002) 

1 002 : the resource name of the target has not been 
40 found, therefore the request Is forwarded to the next 
node on the backbone subnetwork spanning tree 
and the procedure terminates on step (1004). 
1003 : the resource name of the target has been 
found, therefore the request is forwarded on the link 
45 brkige to the Directory Servk;es Proxy located in 
the border node of the access subnetwork. The pro- 
cedure terminates on step (1004). 



901 : a test determines whether or not the resource 
name of the target resource matches a proxy direc- so 
tory database entry (resource kJentifier prefix 
stored in the directory datat)ase of the access bor- 
der node). 

If the resource name matches an entry of the 55 
proxy directory database (a resource identifier 
prefix), the procedure goes on with step (902) 
If the resource name does not match any entry 



Link bridge 

[0068] The selection of a link brkige between a 
k)ackbone and an access border node is the responsibil- 
ity of the access subnetworie A simple criterion based 
on the access subnetwork topology allows the selection 
of a unique link brkJge since the Topology DataBase is 
the same for each node within a given access subnet- 
works. The node at the origin of the link candidate for 
being the link bridge calls an initialization procedure for 
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setting up the Directory Services Proxies in both access 
and backtxxie border nodes. 
[0069] The Rgure 1 1 shows the selection process 
of a link bridge between nodes B and D and the initiali- 
zation of the corresponding Directory Services Proxies s 
(access and backbone proxies). 

• 1 1 01 : Node (A) having the responsibility tor select- 
ing a link bridge sends a message to alt subnetwork 
nodes informing them that link B-D has been io 
selected. At receptbn of this message, all subnet- 
work nodes send to node (B) at the origin of that 
link the set of the resource identifier prefixes they 
manage. 

1102 : Node (B) Initializes the access subnetwork is 
Directory Services Proxy with the resource identi- 
fier prefixes of all subnetwork nodes and adds its 
own prefixes. Then, it sends to the backbone border 
node (D) a request with all the resource identifier 
prefixes known in the access subnetwork for initial- 20 
izing the backbone subnetwork Directory Services 
Proxy. 

• 1103 : Node (D) initializes the backbone subnet- 
work Directory Services Proxy and stores the 
received resource kientif ier prefixes. Then, it sends 25 
a reply to the access node (B). 

1104 : Node (B) returns an acknowledgement to 
node (A) to confirm the link bridge set-up. 

[0070] The backbone side is passive but keeps a 30 
tiveness with the access skie to confirm the backtx)ne 
proxy existence on behalf of this access subnetwork 
Any topology change inskle the access subnetwork can 
invalidate the link brktge and restart another initializa- 
tion process. 35 

Spanning Tree 

[0071 ] The network is no more managed by a single 
spanning tree but by as many spanning trees as subnet- 40 
works (access subnetworks plus backtx}ne subnet- 
work). Each subnetwork nnaintains its own spanning 
tree independently The advantage is obviously the flex- 
ibility, the fast response time plus the capacity to rear- 
range a subnetwork without impacting the whole 4S 
network. The spanning tree algorithm checks the sut> 
network kJentifier of every node that can be reached 
and limit the set-up to those pertaining to the same 
access network. To provide a complete connectivity to 
Directory Services Proxies, a link (bridge link) is so 
selected automatically between each access subnet- 
work and the backbone network. The access subnet- 
work is responsible of selecting this link. The border 
nodes on the selected link automatically activate the 
Directory Services Proxy functions. ss 
[0072] While the invention has been particularly 
shown and desaibed with reference to a preferred 
embodiment, it wilt be understood that various changes 
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in form and detail may be made therein without depart- 
ing from the spirit, and scope of the inventton. 

Claims 

J. A method in an access border node of locating a 
network resource in a packet switching network 
divided in a backbone subnetwork connected to 
one or a plurality of access subnetworks, said net- 
work comprising a plurality of nodes interconnected 
witii transmission links, said access subnetworks 
comprising one or a plurality of access border 
nodes directly connected to the backbone subnet- 
work, said bacMDone subnetwork comprising one or 
a plurality of backbone border nodes directly con- 
nected to the access subnetworks, border nodes of 
different subnetworks being connected by txx-der 
links, said method involving the steps of: 

• receiving (900) a query message comprising a 
resource name, said resource name including 
a prefix: 

• comparing (901) said resource name prefix 
with tiie prefixes stored in an access txxder 
node directory database, sakJ access border 
node directory database comprising prefixes of 
the resources local to the access border node 
subnetwork; 

determining (901) whether tiie resource name 
relates to a resource which is local to the 
access border node subnetwork or not; 

• fonwarding (903) said query message to an 
adjacent backbone tx>rder node when said 
resource name relates to a resource which is 
not local to the access border node subnet- 
work. 

2. The method according to the preceding claim, com- 
prising the further step of : 

• multicasting (902) sa\6 query message witiiin 
the access border node subnetwork when sakl 
resource name relates to a resource local to 
said access border node subnetwork. 

3. The method according to the preceding daim 
wherein step of multicasting said query message 
comprises tiie step of forwarding said query mes- 
sage along a local spanning tree defined witiiin the 
access bader node subnetwork. 

4. The metiiod according to any one of the preceding 
claims comprising the step of: 

• receiving (1101) from other nodes in the 
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access border node subnetwork, the prefixes 
of the resources they manage; 

• adding the pref ixes of the resources the access 
border node nonage locally: 

• initializing (1102) the access border node 
directory database with the prefixes of the 
resources local to the access txvder node sub- 
network. 

5. The method according to the preceding claim com- 
prising the further step of: 

• IbnA^rding (1102) to the adjacent backbone 
border node a copy of the access border node 
directory database. 

6. A method in a backbone border node of locating a 
network resource in a packet switching network 
divided in a backbone subnetwork connected to 
one or a plurality of access subnetworks, said net- 
work comprising a plurality of nodes interconnected 
with transmission links, said access subnetworks 
comprising one or a plurality of access kx)rder 
nodes directly connected to the backbone subnet- 
work, said backbone subnetwork comprising one or 
a plurality of backbone tx)rder nodes directly con- 
nected to the access subnetworks, border nodes of 
different subnetworks being connected by border 
links, said method involving the steps of : 

• receiving (1000) a query message comprising 
a resource name, said resource name includ- 
ing a prefix: 

• comparing (1001) said resource name prefix 
with the prefixes stored in one or a plurality of 
backbone border node directory databases, 
each backbone border rxxie directory data- 
base corresponding to an access subnetwork 
managed by the backbone border node; 

• determining (1001) whether the resource name 
relates to a resource which belongs to an 
access subnetwork that the backbone kx)rder 
node manages or not: 

• fonvarding (1003) said query message to an 
adjacent access border node when said 
resource name relates to a resource which 
belongs to an access border node subnetwork 
managed by the backbone border. 

7. The method according to the preceding claim com- 
prising the further step of : 
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the backbone siA)netwprk when said resource 
name relates to a resource which does not 
belong to any of the access border node sut>- 
networks managed by the backbone txxder 
node. 

The method according to the preceding daim 
wherein said step of multicasting said query mes- 
sage comprises the step of forwarding said query 
message along a local spanning tree d^ined within 
the backtx)ne subnetwork. 

The method according to any one of claims 6 to 8 
comprising the further steps of: 

• receiving from each subnetwork managed by 
the backtx)ne border node, a access border 
node directory database. 

• initializing (1103) the backbone border node 
directory databases with the received access 
border node directory databases. 

The method according to any one of the preceding 
wherein within each access subnetwork, there is 
one and only one access border node with an 
access border node directory database connected 
to a backbone subnetwork, border node comprising 
one or a plurality of backbone border node directory 
databases. 

The method according to any one of the preceding 
claims wherein each node has access to a topology 
of the subnetwork it belongs to. 



12. The method according to any one of the preceding 
daims wherein the topology of each subnetwork 
comprises information concerning the subnetwork 
nodes and subnetwork links and information con- 

40 earning the adjacent border nodes and border links. 

13. The method according to any one of the preceding 
daims wherein said access subnetworks may have 
direct links in between but an access subnetwork 

45 should not be used for transmitting traffic from an 
access node to another. 

14. An access border node for carrying out the method 
according to any one of claims 1 to 5 and 10 to 13. 

50 

15. A backbone border node for carrying out the 
method according to any one of claims 6 to 1 3. 

16. A network comprising nodes according ot any one 
55 of claims 14 to 15. 
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